热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python操作MySQL(pymysql模块)详解及示例代码

本文介绍了使用Python操作MySQL数据库的方法,详细讲解了pymysql模块的安装和连接MySQL数据库的步骤,并提供了示例代码。内容涵盖了创建表、插入数据、查询数据等操作,帮助读者快速掌握Python操作MySQL的技巧。


目录

python连接mysql数据库

操作表与数据




详解

python连接mysql数据库


pymysql是一个第三方模块,需要通过pip install pymysql进行安装。



    import pymysql


    # 连接mysql数据库
    cOnn= pymysql.connect(host='mysql服务器ip',
                          port='mysql服务器端口(默认为3306)',
                          user='mysql服务器用户名',
                          password='mysql服务器用户密码',  
                          database='mysql服务器数据库',
                          charset='utf8')  # 注意:charset='utf8' 不能写成utf-8




    # 使用 cursor()方法 创建一个游标对象 cursor
    cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多

    (左右滑动查看完整python代码)




    操作表与数据


    创建表


      import pymysql


      # 连接mysql数据库
      cOnn= pymysql.connect(host='mysql服务器ip',
                            port='mysql服务器端口(默认为3306)',
                            user='mysql服务器用户名',
                            password='mysql服务器用户密码',
                            database='mysql服务器数据库',
                            charset='utf8')




      # 使用 cursor()方法 创建一个游标对象 cursor
      cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
      # cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多




      # 使用 execute()方法 执行sql,如果表存在则删除
      cursor.execute("DROP TABLE IF EXISTS user")


      # 创建表
      sql = '''CREATE TABLE user (
              NAME CHAR(20) NOT NULL,
              AGE INT,  
              SEX CHAR(1),
              INCOME FLOAT)'''


      # 执行sql
      cursor.execute(sql)


      # 关闭游标
      cursor.close()


      # 关闭数据库连接
      conn.close()

      (左右滑动查看完整python代码)




      操作数据(查询)


        import pymysql


        # 连接mysql数据库
        cOnn= pymysql.connect(host='mysql服务器ip',
                              port='mysql服务器端口(默认为3306)',
                              user='mysql服务器用户名',
                              password='mysql服务器用户密码',
                              database='mysql服务器数据库',
                              charset='utf8')




        # 使用 cursor()方法 创建一个游标对象 cursor
        cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
        # cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多




        sql = "SELECT * FROM user WHERE INCOME > %s" % (1000)
        try:
           cursor.execute(sql)  # 执行SQL语句
           print(cursor.rowcount)  # 获取查出多少行结果
           print(cursor.fetchone())  # 获取一条结果
           print(cursor.fetchmany(10))  # 获取10条结果
           print(cursor.fetchall())  # 获取全部结果
        except Exception as e:
           print(f"SQL执行失败:{e}")




        # 关闭游标
        cursor.close()


        # 关闭数据库连接
        conn.close()

        (左右滑动查看完整python代码)




        操作数据(增删改)


          import pymysql


          # 连接mysql数据库
          cOnn= pymysql.connect(host='mysql服务器ip',
                                port='mysql服务器端口(默认为3306)',
                                user='mysql服务器用户名',
                                password='mysql服务器用户密码',
                                database='mysql服务器数据库',
                                charset='utf8')


          cursor = conn.cursor()  # 创建一个游标对象


          # 增
          sql = "INSERT INTO user(NAME,AGE, SEX, INCOME) \
                VALUES (%s,  %s,  %s,  %s )" % \
                ('pamela', 18, 'F', 1000)


          # 删
          sql = "DELETE FROM user WHERE AGE > %s" % (20)


          # 改
          sql = "UPDATE user SET AGE = AGE + 1 WHERE SEX = '%s'" % ('M')


          try:
             cursor.execute(sql)  # 执行SQL语句
             conn.commit()  # 提交到数据库执行,对存储的数据修改后需要commit
          except Exception as e:
             print(f"SQL执行失败:{e}")
             conn.rollback()  # 如果发生错误则回滚




          cursor.close()  # 关闭游标


          conn.close()  # 关闭数据库连接

          (左右滑动查看完整python代码)




          注意:sql注入问题


          给sql语句传参数,要注意sql注入的问题,传参数不要通过字符串拼接,要通过execute方法来传。


            import pymysql


            # 连接mysql数据库
            cOnn= pymysql.connect(host='mysql服务器ip',
            port='mysql服务器端口(默认为3306)',
            user='mysql服务器用户名',
            password='mysql服务器用户密码',
            database='mysql服务器数据库',
            charset='utf8')
            cursor = conn.cursor() # 创建一个游标对象,查询返回元组


            # sql = "SELECT * FROM user WHERE INCOME > %s" % (1000)
            sql = "SELECT * FROM user WHERE INCOME > %s"
            try:
            cursor.execute(sql, (1000,)) # 执行SQL语句,在第二个参数中传参(把所有参数放在一个元组中)
            except Exception as e:
            print(f"SQL执行失败:{e}")




            cursor.close() # 关闭游标


            conn.close() # 关闭数据库连接

            (左右滑动查看完整python代码)




            其他


            数据备份


              语法:
              备份数据(在cmd命令行直接执行)
              mysqldump -h服务器 -u用户名 -p密码 数据库名 > 备份文件.sql




              #单库备份
              mysqldump -h127.0.0.1 -uroot -p123 db1 > db1.sql
              mysqldump -h127.0.0.1 -uroot -p123 db1 table1 table2 > db1-table1-table2.sql


              #多库备份
              mysqldump -h127.0.0.1 -uroot -p123 --databases db1 db2 db3 > db1_db2_db3.sql


              #备份所有库
              mysqldump -h127.0.0.1 -uroot -p123 --all-databases > all.sql

              (左右滑动查看完整内容)




              数据恢复


                语法:
                恢复数据(在mysql中执行命令)
                切换到一个要备份的数据库中
                source 备份文件.sql




                #方法一:
                命令行:
                mysql -uroot -p123 all.sql


                #方法二:
                mysql中:
                use db1;
                SET SQL_LOG_BIN=0;   #关闭二进制日志,只对当前session生效
                source /root/db1.sql

                (左右滑动查看完整内容)




                事务和锁


                  begin;  # 开启事务
                  select * from user where NAME = 'pamela' for update;  # 查询,for update添加行级锁(select语句后面加一个for update)
                  update user set INCOME=10000 where NAME = 'pamela'; # 完成更新
                  commit;  # 提交事务,释放行级锁

                  (左右滑动查看完整内容)






                  推荐阅读
                  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
                  • 深入解析TCP/IP五层协议
                    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
                  • 对象自省自省在计算机编程领域里,是指在运行时判断一个对象的类型和能力。dir能够返回一个列表,列举了一个对象所拥有的属性和方法。my_list[ ... [详细]
                  • Python处理Word文档的高效技巧
                    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
                  • 通过Web界面管理Linux日志的解决方案
                    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
                  • 本文详细解释了华为ENSP模拟器中常用的命令,涵盖用户模式、系统模式、接口模式和地址池视图模式下的操作。这些命令对于进行计算机网络实验至关重要,帮助用户更好地理解和配置路由器及PC机的通信。 ... [详细]
                  • 华为USG基于源地址的多出口策略路由配置
                    网络拓扑如下:组网情况:企业用户主要有技术部(VLAN10)和行政部(VLAN20),通过汇聚交换机连接到USG。企业分别通过两个不同运营商(ISP1和ISP2)连接到 ... [详细]
                  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
                  • 开发笔记:9.八大排序
                    开发笔记:9.八大排序 ... [详细]
                  • PHP 过滤器详解
                    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
                  • 利用决策树预测NBA比赛胜负的Python数据挖掘实践
                    本文通过使用2013-14赛季NBA赛程与结果数据集以及2013年NBA排名数据,结合《Python数据挖掘入门与实践》一书中的方法,展示如何应用决策树算法进行比赛胜负预测。我们将详细讲解数据预处理、特征工程及模型评估等关键步骤。 ... [详细]
                  • 本文详细介绍了Java Web应用程序中的过滤器(Filter)功能,包括其作用、实现方式及配置方法。过滤器可以在请求到达目标资源之前对其进行预处理,并在响应返回给客户端之前进行后处理。 ... [详细]
                  • JavaScript 基础语法指南
                    本文详细介绍了 JavaScript 的基础语法,包括变量、数据类型、运算符、语句和函数等内容,旨在为初学者提供全面的入门指导。 ... [详细]
                  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
                  • Python实现斐波那契数列的方法与优化
                    本文详细介绍了如何在Python中编写斐波那契数列,并探讨了不同的实现方法及其性能优化。通过递归、迭代和公式法,读者可以了解每种方法的优缺点,并选择最适合自己的实现方式。 ... [详细]
                  author-avatar
                  青藤摄影876
                  这个家伙很懒,什么也没留下!
                  PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
                  Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有